
<!DOCTYPE html>
<html lang="en">
    <head><meta name="generator" content="Hexo 3.9.0">
    
        <title>FairyGUI - 控制器</title>
    
        <meta charset="utf-8">
        <meta name="description" content="FairyGUI教程">
        <meta name="keywords" content="FairyGUI,FGUI,FairyGUI教程">
        
        <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">

        <meta property="og:type" content="article">
        <meta property="og:title" content="-控制器FairyGUI">
        <meta property="og:description" content="FairyGUI教程">

        <meta name="twitter:card" content="summary">
        <meta name="twitter:title" content="控制器 — FairyGUI">
        <meta name="twitter:description" content="FairyGUI教程">

      <!--  <link href='//fonts.proxy.ustclug.org/css?family=Source+Sans+Pro:300,400,600|Roboto Mono' rel='stylesheet' type='text/css'> -->

        <!-- main page styles -->
        <link rel="stylesheet" href="/docs/css/page.css">

        <!-- this needs to be loaded before guide's inline scripts -->
        <script src="/docs/js/vue.min.js"></script>
        <script>window.PAGE_TYPE = "guide_editor"</script>
    </head>
    <body class="docs">        <div id="mobile-bar" data-bg-text="FairyGUI">
            <a class="menu-button"></a>
        </div>
        <div id="header">
  <ul id="nav">
    <li><a href="/docs/guide/" class="nav-link current">教程</a></li>
<li><a href="/docs/examples/" class="nav-link">在线示例</a></li>
<li><a href="/docs/release_notes/" class="nav-link">发行日志</a></li>
<li><a href="/" class="nav-link">首页</a></li>
  </ul>
</div>

        
            <div id="main" class="fix-sidebar">
                
                    
    <div class="sidebar">
    <ul class="main-menu">
        <li><a href="/docs/guide/" class="nav-link current">教程</a></li>
<li><a href="/docs/examples/" class="nav-link">在线示例</a></li>
<li><a href="/docs/release_notes/" class="nav-link">发行日志</a></li>
<li><a href="/" class="nav-link">首页</a></li>
    </ul>
    <div class="list">
        <ul class="menu-root">
            

	 			
	                
	                <li>
	                    <a href="/docs/guide/index.html" class="sidebar-link">导读</a>
	                </li>
	            
	
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/index.html" class="sidebar-link">编辑器使用基础</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/project_settings.html" class="sidebar-link">项目设置</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/package.html" class="sidebar-link">包</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/branch.html" class="sidebar-link">分支</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/publish.html" class="sidebar-link">发布</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/object.html" class="sidebar-link">元件</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/image.html" class="sidebar-link">图片</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/movieclip.html" class="sidebar-link">动画</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/graph.html" class="sidebar-link">图形</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/loader.html" class="sidebar-link">装载器</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/text.html" class="sidebar-link">文本</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/richtext.html" class="sidebar-link">富文本</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/group.html" class="sidebar-link">组</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/component.html" class="sidebar-link">组件</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/scrollpane.html" class="sidebar-link">滚动容器</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/controller.html" class="sidebar-link current">控制器</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/relation.html" class="sidebar-link">关联系统</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/label.html" class="sidebar-link">标签</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/button.html" class="sidebar-link">按钮</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/combobox.html" class="sidebar-link">下拉框</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/progressbar.html" class="sidebar-link">进度条</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/slider.html" class="sidebar-link">滑动条</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/scrollbar.html" class="sidebar-link">滚动条</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/list.html" class="sidebar-link">列表</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/tree.html" class="sidebar-link">树</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/popup.html" class="sidebar-link">Popup</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/dragdrop.html" class="sidebar-link">Drag&Drop</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/window.html" class="sidebar-link">窗口系统</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/transition.html" class="sidebar-link">动效</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/adaptation.html" class="sidebar-link">适配</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/i18n.html" class="sidebar-link">多国语言</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/export.html" class="sidebar-link">导入和导出</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/preference.html" class="sidebar-link">偏好设置</a>
	                </li>
	            
	                
	                <li>
	                    <a href="/docs/guide/editor/plugin.html" class="sidebar-link">插件</a>
	                </li>
	            
	
	            
	                
	                
	                <li><h3>SDK</h3></li>
	                
	                <li>
	                    <a href="/docs/guide/sdk/laya.html" class="sidebar-link">LayaAir</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/sdk/egret.html" class="sidebar-link">Egret</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/sdk/cocos2dx.html" class="sidebar-link">Cocos2dx</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/sdk/creator.html" class="sidebar-link">Cocos Creator</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/sdk/cryengine.html" class="sidebar-link">Cry Engine</a>
	                </li>
	            

	            
	                
	                
	                <li><h3>SDK - Unity</h3></li>
	                
	                <li>
	                    <a href="/docs/guide/unity/index.html" class="sidebar-link">显示UI面板</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/transform.html" class="sidebar-link">坐标系统</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/atlas.html" class="sidebar-link">纹理集的处理</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/font.html" class="sidebar-link">字体的处理</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/input.html" class="sidebar-link">输入处理</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/event.html" class="sidebar-link">事件机制</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/insert3d.html" class="sidebar-link">插入模型/粒子/Spine/Canvas</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/uipainter.html" class="sidebar-link">曲面UI</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/drawcall.html" class="sidebar-link">DrawCall优化</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/lua.html" class="sidebar-link">在Lua中使用</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/special.html" class="sidebar-link">特色功能</a>
	                </li>
	            
	                
	                
	                <li>
	                    <a href="/docs/guide/unity/faq.html" class="sidebar-link">常见问题</a>
	                </li>
	            

            
        </ul>
    </div>
</div>


<div class="content guide_editor with-sidebar ">
    
      <h1>控制器</h1>
    
    <p>控制器是FairyGUI核心功能之一，它为UI制作中以下类似需求提供了支持：</p>
<ul>
<li><p>分页 一个组件可以由多个页面组成。</p>
</li>
<li><p>按钮状态 按钮通常有按下、鼠标悬浮等多个状态，我们可以利用控制器为每个状态安排不同的显示内容。</p>
</li>
<li><p>属性变化 利用控制器，我们可以使元件具有多个不同的形态，并且可以方便地切换。</p>
</li>
</ul>
<h2 id="控制器设计"><a href="#控制器设计" class="headerlink" title="控制器设计"></a>控制器设计</h2><p>每个组件都可以创建一个或多个控制器，如下图所示：</p>
<p><img src="../../images/QQ20191211-121854.png" alt></p>
<ol>
<li>点击控制器名称，显示控制器设计界面。</li>
<li>点击控制器页面按钮，切换页面。</li>
<li>增加控制器。</li>
</ol>
<p>控制器设计页面如下：</p>
<p><img src="../../images/QQ20191211-122014.png" alt></p>
<ul>
<li><p><code>名称</code> 控制器的名称。同一组件内的控制器请不要同名。</p>
</li>
<li><p><code>备注名</code> 控制器的备注名，用于加强理解。</p>
</li>
<li><p><code>首页</code> 控制器创建后的默认页面。</p>
<ul>
<li><code>第一页</code> 这是默认值。一般控制器创建后都是在第一页（索引为0的页面）。</li>
<li><code>指定页面</code> 可以指定某个页面。</li>
<li><code>匹配分支名称</code> 跳转到名称和活跃分支名称相同的页面。假设第3页的名称是en，而当前分支是en，那么控制器创建后就自动跳转到第3页。</li>
<li><p><code>匹配变量名称</code> 跳转到名称和指定变量值相同的页面。见下例：</p>
<p><img src="../../images/QQ20191211-134436.png" alt></p>
<p>在编辑器内，变量可以在“项目设置-&gt;自定义属性”里定义。<strong>在代码里，变量需要通过UIPackage.SetVar定义。</strong></p>
</li>
</ul>
</li>
<li><p><code>导出为组件属性</code> 勾选后，当组件在编辑器里被实例化时，这个控制器将显示在组件的自定义属性面板上。见下例：</p>
<p><img src="../../images/QQ20191211-134850.png" alt> </p>
<p><img src="../../images/QQ20191211-134931.png" alt></p>
<p>可以看到，属性名称使用的是控制器的“备注名”，如果“备注名”为空，则使用控制器的名称。</p>
</li>
<li><p><code>自动调整单选组对象层次</code> 勾选后，组件内所有属于此控制器控制的单选按钮，选中状态的单选按钮自动调整到其他按钮的前面。例如，3个按钮是互相重叠的，在未勾选此选项时效果如左图，勾选后效果如右图：</p>
<p><img src="../../images/20170802231656.png" alt> <img src="../../images/20170802231712.png" alt></p>
</li>
<li><p><code>页面管理</code> 增加、插入、删除页面，以及调整页面顺序。</p>
<p><img src="../../images/QQ20191211-135229.png" alt></p>
</li>
<li><p><code>按钮模板</code> 点击<img src="../../images/QQ20191211-135449.png" alt>，这是快速创建按钮控制器的一种方式。在弹出的菜单中选择一种按钮页面模式后，控制器的名称自动变成“button”，然后自动添加模板中包含的页面。</p>
</li>
<li><p><code>动作</code> 可以定义页面切换时执行一系列动作。详细请参考<a href="#控制器动作">控制器动作</a>。</p>
</li>
</ul>
<h2 id="控制器动作"><a href="#控制器动作" class="headerlink" title="控制器动作"></a>控制器动作</h2><p>可以定义页面切换时执行一系列动作。</p>
<p><img src="../../images/QQ20191211-135643.png" alt></p>
<p>目前支持两种动作，播放动效和切换页面。</p>
<ol>
<li><p>播放动效：指定页面变换时播放一个动效。点击<img src="../../images/QQ20191211-161858.png" alt>进行更精细的设置：</p>
<p><img src="../../images/QQ20191211-135920.png" alt></p>
<ul>
<li><p><code>重复次数</code> 设定动效播放的次数。-1表示循环播放。</p>
</li>
<li><p><code>延迟</code> 设定动效延迟多少秒开始播放。</p>
</li>
<li><p><code>离开页面时停止</code> 如果离开页面时动效仍然在播放，勾选这个选项后将强制停止动效，不勾选的话动效会继续播放到停止（如果是循环的那就一直不会停止）。</p>
</li>
</ul>
</li>
<li><p>切换页面：可以切换其他控制器，实现一个控制器的联动功能。甚至可以设置孩子组件的控制器，前提是该孩子组件的控制器已经设置为“导出为组件属性”。目标页面有两个特殊的<br>选项：<code>相同索引的页面</code>和<code>相同名称的页面</code>。利用这个特殊的选项可以使两个控制器完全同步。</p>
</li>
</ol>
<h2 id="属性控制"><a href="#属性控制" class="headerlink" title="属性控制"></a>属性控制</h2><p>创建了控制器后，下面介绍怎么使用控制器。控制器是通过各个元件的属性控制设置发生作用。</p>
<p>在舞台选定一个元件，可以看到在右边的属性栏出现“属性控制”的面板：</p>
<p><img src="../../images/QQ20191211-140114.png" alt></p>
<h3 id="显示控制"><a href="#显示控制" class="headerlink" title="显示控制"></a>显示控制</h3><p>显示控制指示该元件只有在控制器的活动页面属于参与页面之一时才显示，否则不显示。如果参与页面为空，则显示控制不起作用，元件将一直显示。</p>
<p>设置显示控制的方式：</p>
<p><img src="../../images/QQ20191211-140327.png" alt></p>
<p>左边选择控制器，右边勾选参与页面。</p>
<p>备注：</p>
<ol>
<li><p>显示控制不使用元件本身的可见属性(visible)，两者是独立的，最终是否可见是两者的“与”逻辑结果。</p>
</li>
<li><p>当元件不可见时，它并不会被容器(GComponent)的显示列表剔除，但FairyGUI底层会处理，使不可见的元件不占用渲染资源。不受控制器干扰的显示列表保证了任何时候都可以通过GetChild访问到需要的元件。</p>
</li>
<li><p>有需要时可以通过显示列表视图上的 <img src="../../images/hierarchytb_03.png" alt>屏蔽显示控制器。</p>
<p>假设现在有两个元件A和B，都使用了显示控制，而他们在不同的页面显示。现在想将他们对齐一下，这显然做不到，因为他们不会同时显示，那只能手动填写他们的坐标了，或者将显示控制先取消掉，对齐好了再设置回来。这显然太麻烦，编辑器已经为你考虑到了这一点。</p>
<p>点击“屏蔽控制器”后，所有被控制器隐藏的元件都能显示出来，你就可以方便地应用对齐，或者选中这些元件进行批量的操作了。</p>
<p>这个功能只是辅助UI编辑的，所以只在设计的时候有效，实际运行时并没有屏蔽功能。</p>
</li>
</ol>
<h3 id="显示控制-2"><a href="#显示控制-2" class="headerlink" title="显示控制-2"></a>显示控制-2</h3><p>显示控制-2一般和显示控制搭配使用，它可以实现两个控制器控制一个元件显隐的需求。特别还提供了一个逻辑关系的选项，可以选择“与”或者“或”。</p>
<p><img src="../../images/QQ20191211-140706.png" alt></p>
<h3 id="位置控制"><a href="#位置控制" class="headerlink" title="位置控制"></a>位置控制</h3><p>位置控制是指该元件在不同控制器页面中可以具有不同的XY坐标。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的X、Y属性值，编辑器会自动记录元件在不同页面的属性值，无需额外操作。</p>
<p>位置控制支持动画效果。选中<img src="../../images/QQ20191211-142518.png" alt>后，当控制器页面改变时，元件不是立刻设置新的坐标，而是使用一个缓动到达新的值。点击<img src="../../images/QQ20191211-142602.png" alt>可以设置缓动参数：</p>
<p><img src="../../images/QQ20191211-142615.png" alt></p>
<ul>
<li><code>持续时间</code> 整个缓动过程持续的时间，单位秒。</li>
<li><code>延迟时间</code> 控制器页面切换后，延迟一定时间再开始缓动。单位秒。</li>
<li><code>缓动函数</code> 时间/速度曲线。详细请参考 <a href="../../images/20170802000005.jpg">图解</a> <a href="https://greensock.com/ease-visualizer" target="_blank" rel="noopener">示例</a>。</li>
</ul>
<p>位置控制器支持使用百分比记录坐标。选中<img src="../../images/QQ20191211-145146.png" alt>后，坐标数值将使用百分比记录。例如元件放置在组件水平中心时，x值就记录为50%。当组件大小改变时，切换控制器页面后元件的坐标依然是中心即50%的位置。</p>
<p><strong>位置控制和关联系统的关系</strong></p>
<p>假设控制器C1有2个页面P1和P2，元件N现在设置了位置控制，在P1页面的坐标是V1（50，50），在P2页面的坐标是V2（100，100）。元件N设置了对容器组件右右的关联关系。控制器现在处于P1页，坐标为（50，50）。</p>
<p>现在容器组件大小发生改变，元件N的坐标被关联系统修改为（70，70），这时V1更新为（70，70），V2也同时自动更新为（120，120）。<strong>也就是说，关联系统的动作会应用到所有页面保存的坐标中。</strong></p>
<h3 id="大小控制"><a href="#大小控制" class="headerlink" title="大小控制"></a>大小控制</h3><p>大小控制是指该元件在不同控制器页面中可以具有不同的宽和高以及Scale值。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的宽、高、ScaleX、ScaleY属性值，编辑器会自动记录元件在不同页面的属性值。</p>
<p>大小控制支持动画效果。缓动的设置方式与位置控制是相同的，请参考位置控制。</p>
<h3 id="颜色控制"><a href="#颜色控制" class="headerlink" title="颜色控制"></a>颜色控制</h3><p>颜色控制是指该元件在不同控制器页面中可以具有不同的颜色。只有图片元件（对应图片的变色设置）、文本/富文本元件（对应文字的颜色）和装载器元件（对应载入的图片或动画的变色设置）才支持颜色控制。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的颜色值，编辑器会自动记录元件在不同页面的属性值。</p>
<p>颜色控制支持动画效果。缓动的设置方式与位置控制是相同的，请参考位置控制。</p>
<h3 id="外观控制"><a href="#外观控制" class="headerlink" title="外观控制"></a>外观控制</h3><p>外观控制是指该元件不同控制器页面中可以对具有不同的透明度、变灰、旋转和不可触摸属性。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的透明度、变灰、旋转和不可触摸属性值，编辑器会自动记录元件在不同页面的属性值。</p>
<p>外观控制支持动画效果。但只有透明度和旋转参与缓动，变灰和不可触摸都是立刻设置的。缓动的设置方式与位置控制是相同的，请参考位置控制。</p>
<h3 id="文本控制"><a href="#文本控制" class="headerlink" title="文本控制"></a>文本控制</h3><p>文本控制是指该元件在不同控制器页面中可以具有不同的文本。文本/富文本元件（对应文字的颜色）、标签组件、按钮组件和下拉框组件才支持文本控制。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的文本属性或标题属性，编辑器会自动记录元件在不同页面的属性值。</p>
<h3 id="图标控制"><a href="#图标控制" class="headerlink" title="图标控制"></a>图标控制</h3><p>图标控制是指该元件在不同控制器页面中可以具有不同的图标。只有装载器元件、标签组件、按钮组件才支持图标控制。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的URL属性或图标属性，编辑器会自动记录元件在不同页面的属性值。</p>
<h3 id="动画控制"><a href="#动画控制" class="headerlink" title="动画控制"></a>动画控制</h3><p>动画控制是指该元件在不同控制器页面中可以具有不同的动画相关设置。只有动画和装载器才支持动画控制。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的“播放”和“帧”属性，编辑器会自动记录元件在不同页面的属性值。</p>
<h3 id="字体大小控制"><a href="#字体大小控制" class="headerlink" title="字体大小控制"></a>字体大小控制</h3><p>字体大小是指该元件在不同控制器页面中可以具有不同的字体大小。只有文本、富文本、标签和按钮才支持字体大小控制。</p>
<p>设置控制器后，在不同的控制器页面，你可以调整目标元件的“字体大小”属性，编辑器会自动记录元件在不同页面的属性值。</p>
<h2 id="和按钮的联动"><a href="#和按钮的联动" class="headerlink" title="和按钮的联动"></a>和按钮的联动</h2><p>控制器可以与按钮联动，当普通按钮被按下，或单选/复选按钮选中状态变化时，控制器的页面随之改变。选择一个按钮元件，在右边的“连接”属性设置里，可以设置一个控制器以及一个该控制器的页面：</p>
<p><img src="../../images/QQ20191211-145553.png" alt></p>
<p>设置完成后，根据按钮的类型不同会有不同的反应：</p>
<ul>
<li><p>普通按钮 当按钮被点击时，控制器调转到指定的页面。</p>
</li>
<li><p>单选按钮 当按钮状态从不选中变成选中时，使控制器跳转到指定的页面。<br>当控制器从其他页面切换到指定页面时，按钮变为选中状态。<br>当控制器从指定页面切换到其他页面时，按钮变成不选中状态。</p>
<p>这个特性一般用来实现单选组（RadioGroup）<br>假设目前有3个单选按钮，他们是互斥的，也就是同一时间只有一个按钮是选中状态。这样的设计通常称为单选组。我们可以新建一个含有3个页面的控制器，将每个按钮的单选控制分别连接到这个控制器的3个页面，就实现了这个单选组。</p>
<p><img src="../../images/QQ20191211-145638.png" alt></p>
<p>在程序中，要获得或设置哪个按钮被选中也非常简单，使用控制器的selectedIndex或者selectedPage方法就可以了。</p>
<p>如果再将其他元件的属性控制绑定到这个控制器，例如将各种UI内容使用显示控制安排到各个页面后，那么一个传统意义上的TabControl也实现了。FairyGUI没有TabControl，RadioGroup这些复合组件，因为FairyGUI把这一切的设计自由度都交给了你，无需固化的组件。</p>
<p>如果你的单选组的按钮个数不确定，或者数量很多，那也可以使用列表的方式解决。选择模式为“单选”的列表就相同于一个单选组。详细请阅读列表教程。</p>
</li>
<li><p>复选按钮 当按钮状态从不选中变成选中时，使控制器跳转到指定的页面。<br>当按钮状态从选中变成不选中时，使控制器跳转到除指定页面外的另外一个页面。例如如果控制器具有页面0和1，指定页面是0，当按钮状态从选中变成不选中时，控制器跳转到页面1。<br>当控制器从其他页面切换到指定页面时，按钮变为选中状态；<br>当控制器从指定页面切换到其他页面时，按钮变成不选中状态。</p>
</li>
</ul>
<h2 id="和列表的联动"><a href="#和列表的联动" class="headerlink" title="和列表的联动"></a>和列表的联动</h2><p>列表的“选择控制”可以绑定一个控制器：</p>
<p><img src="../../images/QQ20191211-145743.png" alt></p>
<p>这样当列表选择发生改变时，控制器也同时跳转到相同索引的页面。反之亦然，如果控制器跳转到某个页面，那么列表也同时选定相同索引的项目。</p>
<h2 id="和分页滚动的联动"><a href="#和分页滚动的联动" class="headerlink" title="和分页滚动的联动"></a>和分页滚动的联动</h2><p>溢出处理为“滚动”的组件或列表，如果同时设置了滚动为“页面模式”，那么可以为它们指定一个“分页控制”。</p>
<p><img src="../../images/QQ20191211-145802.png" alt></p>
<p>这样当滚动发生翻页时，控制器也同时跳转到相同索引的页面。反之亦然，如果控制器跳转到某个页面，那么滚动容器同时滚动到相同索引的页面。</p>
<h2 id="和下拉框的联动"><a href="#和下拉框的联动" class="headerlink" title="和下拉框的联动"></a>和下拉框的联动</h2><p>下拉框的“选择控制”可以绑定一个控制器：</p>
<p><img src="../../images/QQ20191211-145743.png" alt></p>
<p>这样当下拉框选择发生改变时，控制器也同时跳转到相同索引的页面。反之亦然，如果控制器跳转到某个页面，那么下拉框也同时选定相同索引的项目。</p>
<h2 id="Controller"><a href="#Controller" class="headerlink" title="Controller"></a>Controller</h2><p>运行时，控制器常用的API有：</p>
<figure class="highlight csharp"><table><tr><td class="code"><pre><span class="line">Controller c1 = aComponent.GetController(<span class="string">"c1"</span>);</span><br><span class="line"></span><br><span class="line"><span class="comment">//通过索引设置控制器的活动页面</span></span><br><span class="line">c1.selectedIndex = <span class="number">1</span>;</span><br><span class="line"></span><br><span class="line"><span class="comment">//如果希望改变控制器时不触发Change事件</span></span><br><span class="line">c1.setSelectedIndex(<span class="number">1</span>);</span><br><span class="line"></span><br><span class="line"><span class="comment">//也可以使用页面的名称设置</span></span><br><span class="line">c1.selectedPage = <span class="string">"page_name"</span>;</span><br><span class="line"></span><br><span class="line"><span class="comment">//获得控制器当前的活动页面</span></span><br><span class="line">Debug.Log(c1.selectedIndex);</span><br></pre></td></tr></table></figure>
<p>控制器改变时有通知事件：</p>
<figure class="highlight csharp"><table><tr><td class="code"><pre><span class="line"><span class="comment">//Unity/Cry/MonoGame</span></span><br><span class="line">c1.onChanged.Add(onChanged);</span><br><span class="line"></span><br><span class="line"><span class="comment">//AS3</span></span><br><span class="line">c1.addEventListener(StateChangeEvent.CHANGED, onChanged);</span><br><span class="line"></span><br><span class="line"><span class="comment">//Egret</span></span><br><span class="line">c1.addEventListener(StateChangeEvent.CHANGED, <span class="keyword">this</span>.onChanged, <span class="keyword">this</span>);</span><br><span class="line"></span><br><span class="line"><span class="comment">//Laya</span></span><br><span class="line">c1.<span class="keyword">on</span>(fairygui.Events.STATE_CHANGED, <span class="keyword">this</span>, <span class="keyword">this</span>.onChanged);</span><br><span class="line"></span><br><span class="line"><span class="comment">//Cocos2dx</span></span><br><span class="line">c1-&gt;addEventListener(UIEventType::Changed, CC_CALLBACK_1(AClass::onChanged, this));</span><br><span class="line"></span><br><span class="line"><span class="comment">//CocosCreator</span></span><br><span class="line">c1.<span class="keyword">on</span>(fgui.Event.STATUS_CHANGED, <span class="keyword">this</span>.onChanged, <span class="keyword">this</span>);</span><br></pre></td></tr></table></figure>
<p>改变控制器页面时，与之连接的属性控制可能带有缓动，如果你要获得缓动结束的通知，可以侦听GearStop事件：</p>
<figure class="highlight csharp"><table><tr><td class="code"><pre><span class="line"><span class="comment">//Unity/Cry/MonoGame</span></span><br><span class="line">aObject.OnGearStop.Add(OnGearStop);</span><br><span class="line"></span><br><span class="line"><span class="comment">//Egret</span></span><br><span class="line">c1.addEventListener(GObject.GEAR_STOP, <span class="keyword">this</span>.onGearStop, <span class="keyword">this</span>);</span><br><span class="line"></span><br><span class="line"><span class="comment">//Laya</span></span><br><span class="line">c1.<span class="keyword">on</span>(fairygui.Events.GEAR_STOP, <span class="keyword">this</span>, <span class="keyword">this</span>.onGearStop);</span><br><span class="line"></span><br><span class="line"><span class="comment">//Cocos2dx</span></span><br><span class="line">c1-&gt;addEventListener(UIEventType::GearStop, CC_CALLBACK_1(AClass::OnGearStop, this));</span><br><span class="line"></span><br><span class="line"><span class="comment">//CocosCreator</span></span><br><span class="line">c1.<span class="keyword">on</span>(fgui.Event.GEAR_STOP, <span class="keyword">this</span>.onGearStop, <span class="keyword">this</span>);</span><br></pre></td></tr></table></figure>
<p>如果你正在做界面的初始化，可能不希望出现任何缓动。可以这样做：</p>
<figure class="highlight csharp"><table><tr><td class="code"><pre><span class="line"><span class="comment">//禁止所有控制器引起的缓动</span></span><br><span class="line">GearBase.disableAllTweenEffect = <span class="literal">true</span>; </span><br><span class="line">c1.selectedIndex = <span class="number">1</span>;</span><br><span class="line"><span class="comment">//记住要复原</span></span><br><span class="line">GearBase.disableAllTweenEffect = <span class="literal">false</span>;</span><br></pre></td></tr></table></figure>
<p>通过代码设置按钮与控制器的联动的方式是（<strong>一般没有此必要，尽量在编辑器设计完成</strong>）：</p>
<figure class="highlight csharp"><table><tr><td class="code"><pre><span class="line">button.relatedcontroller = aController;</span><br><span class="line">button.relatedPageId = aController.GetPageId(<span class="number">1</span>);</span><br></pre></td></tr></table></figure>
<p>可以用代码设置属性控制：（<strong>一般没有此必要，尽量在编辑器设计完成</strong>）：</p>
<figure class="highlight csharp"><table><tr><td class="code"><pre><span class="line"><span class="comment">//GearXXX对象是控制器和属性之间的连接。0-显示控制，1-位置控制，2-大小控制，</span></span><br><span class="line"><span class="comment">// 3-外观控制，4-颜色控制，5-动画控制，6-文字控制，7-图标控制</span></span><br><span class="line">GearDisplay gearDisplay = obj.GetGear(<span class="number">0</span>);</span><br><span class="line"></span><br><span class="line">gearDisplay.controller = obj.parent.GetController(<span class="string">"c1"</span>);</span><br><span class="line"><span class="comment">//注意这里是页面的id，不是索引或者名称。可以通过Controller.GetPageIdByName转换。</span></span><br><span class="line">gearDisplay.pages = <span class="keyword">new</span> <span class="keyword">string</span>[] &#123; ... &#125;; </span><br><span class="line"></span><br><span class="line">GearXY gearXY = obj.GetGear(<span class="number">1</span>);</span><br><span class="line">gearXY.tweenConfig.duration = <span class="number">0.5f</span>;</span><br></pre></td></tr></table></figure>

    
    <div class="footer">
      发现错误或想贡献文档?
      <a href="https://github.com/fairygui/fairygui.github.io/tree/master/src/guide/editor/controller.md" target="_blank">
        在 Github 上编辑此文档!
      </a>
    </div>
</div>

                
            </div>
            <script src="/docs/js/smooth-scroll.min.js"></script>
        

        <!-- main custom script for sidebars, version selects etc. -->        
        <script src="/docs/js/css.escape.js"></script>
        <script src="/docs/js/common.js"></script>
    </body>
</html>
